

DOESTOL ICHE

FIG. 1



| UNIT  |                                                               | REGISTER F          | TLE ACCESS              |
|-------|---------------------------------------------------------------|---------------------|-------------------------|
| GROUP | OPERATIONS                                                    | PRIMARY<br>DATAPATH | ALTERNATIVE<br>DATAPATH |
| A     | - GENERAL ARITHMETIC<br>- BOOLEAN AND CONTROL REGISTER ACCESS | R/W                 | R                       |
| С     | - COMPARE, SHIFT, BOOLEAN<br>- ARITHMETIC: ADD, SUB           | R/W                 | R                       |
| S     | -SHIFT, ROTATE, EXTENDED BOOLEAN<br>-ARITHMETIC: ADD, SUB     | R/W                 | R                       |
| М     | - MULTIPLY<br>- ARTHMETIC: ADD, SUB                           | R/W                 | R                       |
| D     | - LOAD<br>- STORE<br>- ADDRESS COMPUTATION                    | R FROI              | BOTH<br>M BOTH<br>BOTH  |
| Р     | - BRANCH                                                      | R FROI              | и вотн                  |

FIG. 3

R=READ, W=WRITE



| STAGE | FUNCTION                                             |
|-------|------------------------------------------------------|
| F0    | SEND PC TO PROGRAM MEMORY CONTROLLER. LDIP ASSIGNED. |
| F1    | CACHE BLOCK SELECT.                                  |
| F2    | ADDRESS PHASE OF INSTRUCTION CACHE ACCESS.           |
| F3    | DATA PHASE OF INSTRUCTION CACHE ACCESS.              |
| F4    | FETCH PACKET SENT TO DSP.                            |

| STAGE | FUNCTION                                                                |
|-------|-------------------------------------------------------------------------|
| D0    | DETERMINE VALID INSTRUCTIONS IN CURRENT FETCH PACKET.                   |
| D1    | SORTS INSTRUCTIONS IN EXECUTE PACKET ACCORDING TO DESTINATION UNITS.    |
| D2    | INSTRUCTIONS SENT TO DESTINATION UNITS. CROSSPATH REGISTER READS OCCUR. |
| D3    | UNITS DECODE INSTRUCTIONS.<br>REGISTER FILE READ (2ND PHASE).           |

## FIG. 5a

FIG. 5b

| UNIT          | STAGE | FUNCTION                                                                                    |
|---------------|-------|---------------------------------------------------------------------------------------------|
| NON<br>M UNIT | E     | EXECUTION OF OPERATION BEGINS AND COMPLETES. FULL RESULT AVAILABLE AT END OF CYCLE.         |
| M UNIT        | мо    | EXECUTION OF MULTIPLY OPERATION BEGINS.  (OR, NON-MULTIPLY OPERATION BEGINS AND COMPLETES.) |
| M UNIT        | М1    | MULTIPLY OPERATION CONTINUES. (OR, NON-MULTIPLY RESULT WRITTEN TO REGISTER FILE (PHASE 1).) |
| M UNIT        | М2    | MULTIPLY OPERATION COMPLETES.                                                               |

## FIG. 5c

| STAGE | FUNCTION                                                       |
|-------|----------------------------------------------------------------|
| E     | ADDRESS GENERATION OCCURS. REGISTER FILE ACCESS FOR READ DATA. |
| LO    | LOAD ADDRESS GENERATED DURING E IS SENT TOWARDS THE DMC.       |
| L1    | ADDRESS DECODE, TC ARBITRATION, TAG COMPARES.                  |
| L2    | ADDRESS DECODE, TC ARBITRATION, TAG COMPARES.                  |
| L3    | ADDRESS PHASE OF DATA CACHE ACCESS.                            |
| L4    | DATA PHASE OF DATA CACHE ACCESS.                               |
| L5    | 64-BIT DATA SENT TO DSP.                                       |

## FIG. 5d

| STAGE | FUNCTION                                                        |
|-------|-----------------------------------------------------------------|
| E     | ADDRESS GENERATION OCCURS. REGISTER FILE ACCESS FOR WRITE DATA. |
| S0    | ADDRESS SENT TO DMC.                                            |
| S1    | ADDRESS DECODE IN DMC. WRITE DATA ALIGNMENT.                    |
| S2    | TAG COMPARE IN DMC. WRITE DATA SENT TO DMC.                     |
| S3    | ADDRESS PHASE IN DATA CACHE.                                    |
| S4    | DATA PHASE IN DATA CACHE.                                       |





OGGETO" LOTEOO



М

D

Ρ

.M1

.D

P.



|   | [PREDIC         | CATION REG] IN                       | ISTRUCTION_M                                                                                   | EMONIC                                             | -UNIT                                  | -DATAPATH-(                    | CROSSPAT         | H OP1 | , OP2, DS            | T |
|---|-----------------|--------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------|--------------------------------|------------------|-------|----------------------|---|
| ٧ | .UI<br>DA<br>CR | NIT<br>TAPATH<br>ROSSPATH<br>P1, OP2 | =TO BE SCI<br>G] =REGISTER<br>=A,C,S,M,D,<br>=1 FOR D/<br>=X IF ONE<br>=SOURCE  <br>=DESTINATI | CONTAII<br>P UNIT<br>ATAPATH<br>OPERAI<br>REGISTER | NING I<br>GROUF<br>A, 2<br>ND CO<br>RS | PREDICATIO<br>PS<br>FOR DATAPA | n value<br>ath b |       |                      | • |
|   | UNIT            | ASSEMBLY                             | NOTATIONS                                                                                      |                                                    | ASSEMI                                 |                                |                  | WITH  |                      |   |
|   | GROUP           | DATAPATH A                           | DATAPATH B                                                                                     | {                                                  | EXAMPI                                 | LES                            | С                | ROSSF | PATH                 |   |
|   | Α               | .A1                                  | .A2                                                                                            | ADD<br>SUB                                         |                                        | 1,A2,A3<br>31,B2,B3            | ADD<br>SUB       |       | A1,B2,A3<br>B1,A2,B3 |   |
|   | С               | .C1                                  | .C2                                                                                            |                                                    |                                        | A1,A2,A3<br>B1,B2,B3           |                  |       | A1,B2,A3<br>B1,A2,B3 |   |
|   | S               | .S1                                  | .S2                                                                                            | SHL<br>SHL                                         |                                        | 1,A2,A3<br>31,B2,B3            | SHL<br>SHL       |       | A1,B2,A3<br>B1,A2,B3 |   |

FIG.15

.M1 A1,A2,A3

.M2 B1,B2,B3

.D +A8,A12

.D A8,\*A12

**A8** 

ADDAH .D A8,A2,B1

**MPY** 

**MPY** 

.M1X A1,B2,A3

.M2X B1,A2,B3

n/a

n/a

**MPY** 

**MPY** 

LDB

**STB** 

В

.M2

**D2** 

**READ ADDRESS** 

15x5

VALID

15x1

FIG. 9



osezsun loizoc





OSEXSHOLLOISOO





91

| 1            | •  | • |
|--------------|----|---|
| Ą            |    |   |
| ind<br>Stand | Į  | 1 |
| Ę            | ì  | į |
| 2            | ٠, | į |
|              | Į. |   |
| =            | E  | = |
| Had?         | =  | 1 |
| Ē            | i  |   |
|              | =  | = |
| i i          | _  | 1 |
| ******       | -  | 1 |
| 11011        | į  | 7 |
| · brist      | -  | 9 |
| in or        |    |   |

| Mnemonic             | Action         | Operation                                                                      |       |
|----------------------|----------------|--------------------------------------------------------------------------------|-------|
| LDB[U]<br>168        | Load byte      | Memory B/A XXXXXXba → SSSSSba (signed (s)) XXXXXXba → 0000000ba (unsigned (u)) |       |
| LDH[U]<br><u>170</u> | Load halfword  | Memory B/A XXXXdcba → SSSSdcba (s) XXXXdcba → 0000dcba (u)                     | FIG.  |
| LDW 172              | Load word      | Memory B/A<br>hgfedcba → hgfedcba                                              |       |
| LD0<br>174           | Load double    | Memory B/0 A/E<br>ponmlkji hgfedcba → ponmlkji hgfedcba                        |       |
| Mnemonic             | Action         | Operation                                                                      |       |
| STB 176              | Store byte     | B/A Memory<br>XXXXXXba → 000000ba                                              |       |
| STH 178              | Store halfword | B/A Memory<br>XXXXdcba → 0000dcba                                              | 010   |
| STW 180              | Store word     | B/A Memory<br>hgfedcba → hgfedcba                                              | 1.19. |
| STD 182              | Store double   | B/O A/E Memory<br>ponmlkji hgfedcba — ponmlkji hgfedcba                        |       |

| Ī             | _  | Ì |
|---------------|----|---|
| i.            |    |   |
| H.            | Ţ  |   |
| i i           | Ĭ  |   |
| 7             | -  |   |
|               | ř  |   |
| model II that | F  | = |
| -             | -  | 2 |
| ŝ.            | _  | : |
| Ξ             |    |   |
| Ē             |    |   |
| i a           | _  |   |
| 1             | _  | 1 |
| 1440          | į  | - |
| Carry.        | =  |   |
| i             | == |   |

|           | ·                                                        | _                                                        |                                                          | · · ·                                            |                                                       | · · · · · · · · · · · · · · · · · · ·            | T                                                   |
|-----------|----------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------|
|           |                                                          |                                                          |                                                          | (s)                                              | (s)                                                   | (s)                                              | (s)<br>(u)                                          |
|           |                                                          |                                                          |                                                          | AE<br>SSdcSSba<br>00dc00ba                       | AE<br>SSfeSSba<br>OOfeOOba                            | AE<br>SSSSdcba<br>0000dcba                       | AE<br>SSSSdcba<br>0000dcba                          |
|           | (signed (s))<br>(unsigned (u))                           |                                                          |                                                          | AO<br>SShgSSfe<br>00hg00fe                       | AO<br>SShgSSdc<br>00hg00dc                            | AO<br>SSSShgfe<br>0000hgfe                       | AO<br>SSSSIkji<br>0000lkji                          |
| Operation | (signed (s))<br>(unsigned (t                             | (s)                                                      | (S)                                                      | BE<br>SSIKSSji<br>OOIKOOji                       | BE<br>SSnmSSji<br>00nm00ji                            | BE<br>SSSSIKji<br>00001Kji                       | BE<br>SSSShgfe<br>0000hgfe                          |
| 0         | A/E<br>SSdcSSba<br>00dc00bo                              | A/E<br>SSfeSSba<br>00fe00ba                              | A/E<br>SSSSdcba<br>0000dcba                              | 80<br>SSpoSSnm<br>00po00nm                       | BO<br>SSpoSSIK<br>00po00lk                            | BO<br>SSSSponm<br>0000ponm                       | BO BE<br>SSSSponm SSSShgfe<br>0000ponm 0000hgfe     |
|           | oofe                                                     | VO<br>SSdc<br>OOdc                                       | B/0<br>SSSShgfe<br>0000hgfe                              | <b>†</b> †                                       | <b>†</b> †                                            | <b>†</b> †                                       | <b>†</b> †                                          |
|           | Memory B/0<br>hgfedcba — SShgSSfe<br>hgfedcba — 00hg00fe | Memory B/0<br>hgfedcba — SShgSSdc<br>hgfedcba — 00hg00dc | Memory B/0<br>hgfedcba — SSSShgfe<br>hgfedcba — 0000hgfe | Memory<br>ponmlkji hgfedcba<br>ponmlkji hgfedcba | Memory<br>ponmlkji hgfedcba<br>ponmlkji hgfedcba      | Memory<br>ponmlkji hgfedcba<br>ponmlkji hgfedcba | Memory<br>ponmlkji hgfedcba<br>ponmlkji hgfedcba    |
| Action    | Word: unpack the bytes<br>into halfwords                 | Word: unpack the bytes<br>into halfwords interleaved     | Word: unpack the halfwords into words                    | Double: unpack the bytes into halfwords          | Double: unpack the bytes into halfwords interleaved p | Double: unpack the<br>halfwords into words       | Double: unpack the halfwords into words interleaved |
| Mnemonic  | LDW_ВН[U]<br><u>184</u>                                  | LOW_BHI[U]<br>186                                        | LDW_HW[U]<br>188                                         | LDD_ВН[V]<br><u>190</u>                          | гоо_внг[и]<br>1 <u>92</u>                             | LDD_HW[U]<br><u>194</u>                          | LDD_HW[[U]<br><u>196</u>                            |

## FIG. 18

| Mnemonic    | Action                                                            |                              |                 | d0                                     | Operation                    |                                           |
|-------------|-------------------------------------------------------------------|------------------------------|-----------------|----------------------------------------|------------------------------|-------------------------------------------|
|             | Pack the LS byte of each<br>halfword into a word                  | B/O A/E<br>XXhgXXfe XXdcXXba | A/E<br>XXdcXXba | Memory<br>→ hgfedcba                   | <b>5</b> 0                   |                                           |
|             | Pack the LS byte of each<br>halfword interleaved into<br>a word   | B/O A/E<br>XXhgXXdc XXfeXXba | A/E<br>XXfeXXba | Memory<br>→ hgfedcba                   | λ<br>Σ                       |                                           |
|             | Pack the LS halfword of each word into a word                     | B/0 A/E<br>XXXXhgfe XXXXdcba | A/E<br>XXXXdcba | Memory<br>→ hgfedcba                   | ر<br>ا                       |                                           |
|             | Pack the LS byte of each<br>halfword into a double                | ВО<br>ХХроХХпт               | BE<br>XXIkXXji  | AO<br>XXhgXXfe                         | AO AE<br>XXhgXXfe XXdcXXba - | Memory<br>— ponmikji hgfedcba             |
|             | Pack the LS byte of each<br>halfword interleaved into<br>a double | BO<br>XXpoXXIk               | BE<br>XXnmXXji  | BE AO AE<br>XXnmXXji XXhgXXdc XXfeXXba |                              | Memory<br>— ponmlkji hgfedcba             |
|             | Pack the LS halfword of each word into a double                   | ВО<br>ХХХХропт               | BE<br>XXXXIkji  | AO<br>XXXXhgfe                         | AE<br>XXXXdcba               | Memory<br>→ ponmlkji hgfedcba             |
| //_D<br>210 | Pack the LS halfword of each word interleaved into a double       | BO BE<br>XXXXponm XXXXhgfe   | BE<br>XXXXhgfe  | AO<br>XXXXIkji                         | AE<br>XXXXdcba -             | AE Memory<br>XXXXdcba → ponmlkji hgfedcba |

FIG. 19